热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

上限|时分_ORACLE普通表转换成自动分区表

篇首语:本文由编程笔记#小编为大家整理,主要介绍了ORACLE普通表转换成自动分区表相关的知识,希望对你有一定的参考价值。1、先创建一张和普通表一样的分区表(表的字段太多

篇首语:本文由编程笔记#小编为大家整理,主要介绍了ORACLE普通表转换成自动分区表相关的知识,希望对你有一定的参考价值。


1、先创建一张和普通表一样的分区表(表的字段太多了,这字段是经过筛选用来测试)

创建分区表语法关键定义:

根据年: INTERVAL(NUMTOYMINTERVAL(1,'YEAR'))
根据月: INTERVAL(NUMTOYMINTERVAL(1,'MONTH'))
根据天: INTERVAL(NUMTODSINTERVAL(1,'DAY'))
根据时分秒: NUMTODSINTERVAL( n, 'DAY'|'HOUR'|'MINUTE'|'SECOND')

同时可以通过MAXVALUE来指定最大值,MAXVALUE用实际值代替

--,PARTITION DW_KAD_PRM_DETAILS_PART_MAXVAL values LESS THAN (MAXVALUE)

以上。

先查询出原表最小日期select min(starttime ) from DW_KAD_PRM_DETAILS;

我这边查询出的最小日期是0001/01/01这个特殊值,那么久从这个字段开始,建表语句如下:

create table DW_KAD_PRM_DETAILS_PART
(
prmcode VARCHAR2(50),
prmname VARCHAR2(1000),
prmdesc VARCHAR2(1000),
starttime DATE,
endtime DATE,
prmflagname VARCHAR2(50),
prmtypecode VARCHAR2(50),
prmtypename VARCHAR2(100),
modifytime DATE,
createtime DATE default sysdate
)
tablespace BIDEV_DATA
PARTITION BY RANGE (starttime) interval (numtoyminterval(1, 'month'))
STORE IN (BIDEV_DATA)
(
partition DW_KAD_PRM_DETAILS_PART_SP1 values less than (to_date('0001/01/01','yyyy/mm/dd')) tablespace BIDEV_DATA
--,PARTITION DW_KAD_PRM_DETAILS_PART_MAXVAL values LESS THAN (to_date('2999/12/31','yyyy/mm/dd')) 这里需要自增长,所以不限上限
);
/*-- Create/Recreate indexes
create index IDX1_DW_KAD_PRM_DETAILS_PART on DW_KAD_PRM_DETAILS_PART (PRMCODE)
tablespace BIDEV_DATA
pctfree 10
initrans 2
maxtrans 255
storage
(
initial 64K
next 1M
minextents 1
maxextents unlimited
);*/




2、将原表的数据插入

insert into DW_KAD_PRM_DETAILS_PART
select * from bidev.dw_kad_prm_details where STARTTIME




查看表的效果如下,sys_开头的分区就是数据库自行创建


分区列是不许有空值存在的,如果插入空值则报错ORA-14300

insert into DW_KAD_PRM_DETAILS_PART
select * from bidev.dw_kad_prm_details where STARTTIME is null and rownum<10;

报错信息如下



推荐阅读
author-avatar
幸运幸福摩天轮的世界
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有